/* Siconos is a program dedicated to modeling, simulation and control
 * of non smooth dynamical systems.
 *
 * Copyright 2024 INRIA.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

#ifndef ProjectionOnRollingCone_H
#define ProjectionOnRollingCone_H

/*!\file projectionOnCone.h
 * function to project on cones
 */

#include "SiconosConfig.h"  // for BUILD_AS_CPP // IWYU pragma: keep

enum {
  PROJRCONE_DUAL,
  PROJRCONE_INSIDE,
  PROJRCONE_BOUNDARY_FRICTION,
  PROJRCONE_BOUNDARY_ROLLING,
  PROJRCONE_BOUNDARY_FRICTION_ROLLING
};
#if defined(__cplusplus) && !defined(BUILD_AS_CPP)
extern "C" {
#endif

/**
    projectionOnCone Projection on the second Order Cone in \f$ R^3 \f$, \f$ K
   \{ r, r_1 \geq 0, 0 \sqrt(r_2^2+r_3^2) \geq mu r_1  \} \f$

    \param[in,out] r the vector to be projected
    \param[in] mu the angle of the cone
    \return the type of projection
*/
unsigned int projectionOnRollingCone(double *r, double mu, double mur);

/**
   projectionOnCone Projection on the second Order Cone in \f$ R^3 \f$, \f$ K \{
   r, r_1 \geq 0, 0 \sqrt(r_2^2+r_3^2) \geq mu r_1  \} \f$

   \param[in,out] r the vector to be projected
   \param[in] mu the angle of the cone
   \return the type of projection
*/
unsigned int projectionOn2DRollingCone(double *r, double mu, double mur);

/**
   projectionOnDualCone Projection on the second Order Cone in \f$ R^3 \f$, \f$ K
   \{ r, r_1 \geq 0, 0 mu \sqrt(u_2^2+u_3^2) \geq u_1  \} \f$

   \param[in,out] u the vector to be projected
   \param[in] mu the angle of the cone
   \return the type of projection
*/
unsigned projectionOnDualRollingCone(double *u, double mu, double mur);

void display_status_rolling_cone(unsigned int status);

#if defined(__cplusplus) && !defined(BUILD_AS_CPP)
}
#endif

#endif
